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CLOCK GRID SKEW REDUCTION USING A WIRE TREE ARCHITECTURE 

Background of Invention 

[0001] A typical computer system includes at least a microprocessor and some 
form of memory. The microprocessor has, among other components, arithmetic, 
logic, and control circuitry that interpret and execute instructions necessary for the 
operation and use of the computer system. Figure 1 shows a typical computer 
system (10) having a microprocessor (12), memory (14), integrated circuits (16) 
that have various functionalities, and communication paths (18), i.e., buses and 
wires, that are necessary for the transfer of data among the aforementioned 
components of the computer system (10). 

[0002] The components of a computer system use a reference of time to perform 

the various operations of the computer system. This reference of time is provided 
to the components of the computer system using one or more clock signals. The 
components use the one or more clock signals to determine when to conduct 
certain operations. As computer systems continue to operate at ever-increasing 
frequencies, it becomes more and more important to ensure that the components of 
a computer system receive their clock signals in an accurate and timely manner. A 
mistiming has the potential to cause an error, performance setback, or an outright 
malfunction of the computer system. 

[0003] Figure 2 shows a clock distribution network (20) for a microprocessor (12). 
A reference clock (also known in the art as "system clock" and shown in Figure 2 
as ref_clk), which is typically generated from outside the microprocessor (12), 
serves as an input to a phase locked loop ("PLL") (15). Essentially, the PLL (15) 
uses feedback to maintain a specific phase relationship between its output (shown 
in Figure 2 as chip_clk) and the reference signal. The chip clock from the PLL 
(15) is then distributed to one or more clock drivers/buffers (17), which, in turn. 
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distribute the chip clock to a global clock grid (19). The global clock grid (19) 
feeds the chip clock to various microprocessor components such as local clock 
grids (24) and a feedback loop (26) that feeds the chip clock back to the PLL (14). 
The local clock grids (24) feed the chip clock to base components of the 
microprocessor (12), such as latches (22) and flip-flops (28). 

[0004] As a clock signal, such as the chip clock shown in Figure 2, is propagated 
to the various parts and components of a microprocessor, one or more types of 
system variations may alter the behavior and/or integrity of the clock signal. 
Common system variations include, but are not limited to, voltage variations, 
temperature variations, and process variations. Due to these and other variations 
across a microprocessor, a particular clock signal may arrive at different parts of 
the microprocessor at different times. This difference in the arrival of a clock 
signal at different system components is referred to and known in the art as "clock 
skew." 

[0005] The actual architectural implementation of a clock distribution network is 
another factor that affects clock skew. With the increasing die size and 
complexity of integrated circuit designs, it becomes necessary to have long metal 
wires, known as "interconnects," to distribute a clock signal to the various parts of 
the integrated circuit. Figure 3 a shows a top view of a typical clock distribution 
network. In Figure 3a, clock drivers (also referred to and known as "clock 
drivers") (40) distribute clock signals onto a clock grid (42). The various 
components of an integrated circuit dependent on the clock signals provided by the 
clock drivers (40) are operatively connected to various points along the clock grid 
(42). 

[0006] Figure 3b shows a section of the clock distribution network shown in 
Figure 3a. Particularly, Figure 3b shows the implementation of interconnects (44) 
that connect the clock drivers (40) to the clock grid (42). 
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[0007] Technically, interconnects do not behave as virtual or ideal wires. Instead, 
interconnects behave more like a network of capacitors and resistors. Thus, in 
effect, interconnects are characterized by resistor-capacitor ("RC") delays. Such 
RC delays, which are primarily a function of length, can dominate circuit 
behavior, especially with respect to circuit timing. 

[0008] Figure 3 c shows an expanded view of the section of the typical clock 
distribution network shown in Figure 3b. As discussed above with reference to 
Figure 3b, a clock driver (40) is connected to the clock grid (42) via an 
interconnect (44). Two points, pi and p2, are denoted on the clock grid (42) to 
represent points on the clock grid (42) where the time of arrival of a clock signal is 
at interest. Referring now also to the timing diagram shown in Figure 3d, when a 
clock signal from a particular clock driver (40) is driven to the clock grid (42), the 
clock signal arrives at pi some finite amount of time before it arrives at p2. This 
is due to the fact that the clock signal experiences less RC delay along the path 
from the clock driver (40) to pi than it does along the longer path from the clock 
driver (40) to p2. This difference in arrival time of the clock signal at pi and p2 
results in clock skew as shown in Figure 3d. Such clock skew is typically not 
desirable because components connected to points pi and p2 will be expecting the 
arrival of a clock signal at the same time, but in reality, the clock signal will arrive 
at the components at different times. 

Summary of Invention 

[0009] According to one aspect of the present invention, an integrated circuit 
comprises a clock driver disposed on the integrated circuit, a clock grid disposed 
on the integrated circuit, and at least one interconnect connecting an output of the 
clock driver to the clock grid at a connection point, where the connection points 
resides at a non-peripheral region of the clock grid. 
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[0010] According to another aspect, a computer system comprises an integrated 
circuit having a clock grid, at least one clock driver that provides a clock signal to 
the clock grid, and a transmission structure operatively connecting an output of the 
at least one clock driver to at least one point on the clock grid, wherein the at least 
one point resides at a non-exterior region of the clock grid. 

[0011] According to another aspect, a method for reducing clock skew comprises 
sending a clock signal from a clock driver to a first component through a 
connection point on a clock grid; and sending the clock signal from the clock 
driver to a second component through the connection point, where the connection 
point is at a non-peripheral region of the clock grid. 

[0012] According to another aspect, a transmission structure for driving a signal 
onto a clock grid comprises an interconnect connecting a clock driver to the clock 
grid, where the interconnect connects the clock driver to the clock grid at a 
connection point residing at a non-exterior region of the clock grid. 

[0013] Other aspects and advantages of the invention will be apparent from the 
following description and the appended claims. 

Brief Description of Drawings 

[0014] Figure 1 shows a typical integrated circuit. 

[0015] Figure 2 shows a typical clock distribution network. 

[0016] Figure 3a shows a top view of a typical clock distribution network. 

[0017] Figure 3b shows a section of the typical clock distribution network shown 
in Figure 3a. 

[0018] Figure 3c shows an expanded view of the section of the typical clock 
distribution network shown in Figure 3b. 

[0019] Figure 3d shows a timing diagram in accordance with the expanded view of 
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the section of the typical clock distribution network shown in Figure 3c. 

[0020] Figure 4a shows a section of a clock distribution network in accordance 
with an embodiment of the present invention.. 

[0021] Figure 4b shows an expanded view of the section of the clock distribution 
network shown in Figure 4a. 

[0022] Figure 4c shows a timing diagram in accordance with the expanded view of 
the section of the clock distribution network shown in Figure 4b. 

[0023] Figure 5 shows a clock distribution network in accordance with another 

embodiment of the present invention. 

Detailed Description 

[0024] Embodiments of the present invention relate to a clock skew reduction 
apparatus having a wire tree architecture. Embodiments of the present invention 
further relate to a method for reducing clock skew using wire tree architecture to 
connect one or more clock headers to clock grid. Embodiments of the present 
invention further relate to a clock skew reduction apparatus having a balanced 
wire tree architecture. Embodiments of the present invention further relate to a 
method for reducing clock skew using a balanced wire tree structure to connect 
one or more clock drivers to a clock grid. 

[0025] A clock skew reduction apparatus and method consistent with.the.principles 
of the present invention reduces clock skew on a clock grid of an integrated 
circuit. The clock skew reduction apparatus and method uses a novel interconnect 
structure to decrease clock skew among components connected to the clock grid. 

[0026] Figure 4a shows an exemplary section of a clock distribution network in 
accordance with an embodiment of the present invention. In Figure 4a, one or 
more clock drivers (40) are connected to a clock grid (42) via interconnects (46), 
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where the interconnects (46) connect the clock drivers (40) to non-exterior regions 
of the clock grid (42). The implementation of the interconnects (46) as such 
allows for a more distributed clock signal on the clock grid (42) relative to prior 
art structures that distributed a clock signal along the sides, i.e., periphery, of a 
clock grid. By positioning the interconnects (46) as shown in Figure 4a, a clock 
signal may be provided to a component connected to the clock grid (42) more 
quickly and with less clock skew than in those cases where a clock signal has to 
propagate from an edge of a clock grid to a particular component. 

[0027] Figure 4b shows an expanded view of the section of the clock distribution 
network shown in Figure 4a. As discussed above with reference to Figure 4a, the 
clock drivers (40) are connected to nodes of the clock grid (42) via interconnects 
(46) connected to non-exterior regions of the clock grid (42). Two points, pi and 
p2, are denoted on the clock grid (42) to represent points on the clock grid (42) 
where the time of arrival of a clock signal is at interest. Referring now also to the 
timing diagram shown in Figure 4c, when a clock signal from a particular clock 
driver (40) is driven to the clock grid (42), the clock signal arrives at pi at the 
same time it arrives at p2. This is due to the fact that the clock signal experiences 
the same RC delay along the path from the clock driver (40) to pi as it does along 
the path from the clock driver (40) to p2. In other words, the distance from the 
clock driver (40) to pi is virtually the same as the distance from the clock driver 
(40) to p2. 

[0028] Thus, clock skew among components connected to points pi and p2 is less 
than in those cases where clock driver/clock grid interconnect connectivity as 
shown in Figure 4a is not used. Further, although zero clock skew is achieved as 
shown in Figure 4c, other implementations of the interconnect wire tree 
architecture may not yield zero clock skew due to pi and p2 being at slightly 
different distances from a point on the clock grid (42) at which an interconnect 
(46) is connected. However, those skilled in the art will appreciate that 
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embodiments of the present invention yield reduced clock skew with respect to 
prior art implementations as shown in Figures 3a-3c. In other words, reduced 
clock skew is achieved by propagating a clock signal from a clock driver to a 
clock grid via a non-exterior region of the clock grid rather than propagating the 
clock signal to the clock grid via an exterior region of the clock grid. Those 
skilled in the art will further note that RC delay is a function of distance, and thus, 
by decreasing the distance a signal has to travel, RC delay is reduced accordingly. 

[0029] Figure 5 shows an exemplary clock distribution network in accordance with 
another embodiment of the present invention. In Figure 5, a clock driver (40) is 
connected to a clock grid (42) via interconnects (46) arranged in a balanced wire 
tree structure. In this particular implementation, because there are a larger amount 
of connections from the clock driver (40) to the clock grid (42), the uniformity of 
clock arrival time is improved. Further, in variations of this embodiment, the 
distance a clock signal has to travel to reach a particular component operatively 
connected to the clock grid (42) may be less than the distance required if (1) there 
were a lesser amount of connection points between the clock driver (40) and clock 
grid (42) and (2) if the connection points were at an exterior region of the clock 
grid. This results in a decrease in signal delay to components along the clock grid 
(42), effectively leading to faster performance with less skew. Those skilled in the 
art will appreciate that the number of connection points may be varied according 
to the amount of time delay a component can tolerate with respect to an arrival of 
a clock signal. 

[0030] Those skilled in the art will appreciate that although the wire tree structure 
shown in Figures 5 is referred to as "balanced," other embodiments of the present 
invention may use wire tree structures that are not per se balanced. As long as the 
wire tree structure connects a clock grid to a clock driver, where the connection 
points are not solely at a peripheral region of the clock grid, the principles of the 
present invention are met. Further, the use of a balanced wire tree structure in the 
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drawings is presented for purposes of more easily understanding the present 
invention. Moreover, wire tree structures are also referred to as "transmission 
structures." A transmission structure consistent with the principles of the present 
invention may be implemented by first designating clock drivers to particular 
points on a clock grid. Thereafter, a wire tree, using some conductive material, is 
interlaced within an integrated circuit to form the transmission structure. 

[0031] Advantages of the present invention may include one or more of the 

following. In some embodiments, because an interconnect connects a clock driver 
to a non-exterior, i.e., non-peripheral, region of a clock grid, signal paths from the 
clock driver may be connected on the clock grid so as to allow a reduction in clock 
skew among components operatively connected to the clock grid. 

[0032] In some embodiments, because an interconnect connects a clock driver to a 

non-exterior, i.e., non-peripheral, region of a clock grid, a signal from the clock 
driver to a particular point on the clock grid experiences less RC delay than in the 
case where the clock driver is connected to a peripheral region of the clock grid. 

[0033] In some embodiments, because a wire tree structure is used with a clock 
grid, the wire tree structure may be scalable for use with small and large integrated 
circuits. Further, the simplicity of the balanced wire tree configuration allows for 
easy integration of this technique in the integrated circuit design and 
manufacturing processes. 

[0034] While the invention has been described with respect to a limited number of 
embodiments, those skilled in the art, having benefit of this disclosure, will 
appreciate that other embodiments can be devised which do not depart fi-om the 
scope of the invention as disclosed herein. Accordingly, the scope of the 
invention should be limited only by the attached claims. 
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